草庐IT

运行回显命令的 Docker 参数

全部标签

ruby - 是否可以在 RSpec 中使用参数化规范?

如果我有一个规范需要以不同的值运行以使其驱动真正的实现而不是天真的实现。一个例子:it"shouldreturn'fizz'formultiplesofthree"do@fizzbuzz.get_value(3).should=="fizz"end到目前为止,我还没有找到任何方法将3作为参数传入。下面的规范解决了我的问题,但我想知道这是否是推荐的方法,或者是否有任何其他更好的方法。it"shouldreturn'fizz'formultiplesofthree"do[3,6].each{|number|@fizzbuzz.get_value(number).should=="fizz"

ruby-on-rails - 在 Rails 控制台中创建实例时 Rails 4 强参数失败

可能在这里做了一些愚蠢的事情,但这是我的基本千篇一律类:classLeague在创建一个新的League实例时:2.0.0-p0:001>l=League.new(full_name:'foo',short_name:'bar')WARNING:Can'tmass-assignprotectedattributesforLeague:full_name,short_name我到底做错了什么?这是Rails4.0.0.beta1构建+Ruby2.0**更新**我现在意识到强参数现在是在Controller中强制执行的,而不是在模型中。原来的问题仍然成立。如果它们在Controller级别

ruby-on-rails - ruby 中 CSV.open( ) 的第二个参数/参数是什么?

我想我在这里遗漏了一些非常明显的东西,但是每个人为CSV.open方法输入的第二个参数是什么,在本例中是“wb”,我看到这里放了其他字母,但没有人真正解释它的作用。它有什么作用?CSV.open("path/to/file.csv","wb")do|csv|csvruby文档似乎没有给出任何解释。http://www.ruby-doc.org/stdlib-2.0/libdoc/csv/rdoc/CSV.html谢谢! 最佳答案 来自IOOpenMode文档:"r"只读,从文件开头开始(默认模式)。"r+"读写,从文件开头开始。"w

ruby-on-rails - Rails 3.0.7 -> 如何让测试运行得更快?

我正在运行mysql、database_cleaner、Rspec等。到目前为止我有大约518个测试,它们需要88秒才能运行。这对我来说是NotAcceptable,因为我的应用程序开发才刚刚开始。因此,在进一步深入之前,我想尝试找到减少运行这些测试所需时间的方法-希望不必实际更改测试。在大多数情况下,我尝试使用stub。但是,当我测试模型和查询时,我会使用数据库。我认为database_cleaner正在减慢它们的速度,但我不知道如何在没有它的情况下测试查询和其他内容。使用带有“:memory:”选项的sqlite3似乎只减少了大约10秒(有点令人失望的结果......)我该怎么做才

ruby - Ruby 中的命名命令行参数

有没有办法将命名参数传递给Ruby脚本?我理解ARGV传递参数的方式,但是这要求它们必须有一定的顺序。我想做的是传递命名参数,类似于其他命令行操作。例如:$rubysomeRubyScript.rb-aargumentA-bargumentB有什么想法吗? 最佳答案 有几个选项。OptionParser,在标准库中,是最受欢迎的之一。它可以完全满足您的需求,而且API也很不错。GetOptLong也在标准库中,它重新实现了POSIX风格的命令行。如果您想模拟Unix命令行应用程序,这一切都可以做到。AraT.Howard的Main是

ruby - 从命令行运行 Ruby 库

在对Python非常满意几年后,我刚刚学习了Ruby的基础知识(我仍在使用Python做某些事情),但我想知道是否有成语或hack来解决这个特殊问题问题。我有一个Ruby脚本,我希望能够用它执行requirescript_name,但我也希望能够运行rubyscript_name.rb从终端并将其作为命令行脚本运行。在Python中,这将通过在脚本底部具有以下结构来完成:if__name__=='__main__':#dosomethinghere但是,我似乎找不到Ruby中的等效项。有没有办法检测当前脚本是否正在从命令行运行?也许是一些Kernel::方法之类的?理想情况下,我想要的

ruby-on-rails - 运行 autoconf 时 rvm install 1.9.2 失败?

当我运行时rvminstall1.9.2我在尝试运行autoconf时遇到错误。这是堆栈跟踪:kenmare:ruby-1.9.2-p0lee$rvminstall1.9.2-p0/Users/lee/.rvm/rubies/ruby-1.9.2-p0,thismaytakeawhiledependingonyourcpu(s)...ruby-1.9.2-p0-#fetchingruby-1.9.2-p0-#extractedto/Users/lee/.rvm/src/ruby-1.9.2-p0(alreadyextracted)RunningautoconfErrorrunning'

ruby-on-rails - gem install mysql2 v '0.3.11' 无法在 Yosemite 上运行

在ruby​​版本1.9.3(rvm)上执行mysql2版本0.3.11的捆绑安装或直接gem安装时,我收到以下错误。但是当我安装最新版本0.3.16时它可以工作。我还包含了我的gcc版本以供引用。Gem::Ext::BuildError:ERROR:Failedtobuildgemnativeextension./Users/ginocarlocortez/.rvm/rubies/ruby-1.9.3-p547/bin/rubyextconf.rbcheckingforrb_thread_blocking_region()...yescheckingforrb_wait_for_si

Ruby 使用/附加字符串参数重新引发异常

情况是这样的。我希望doStuff()中的所有异常通过代码冒泡,以便在更高级别处理它们。我还想记录在更高级别的doStuff()中发生任何异常的频率,目前正在这样做:begindoStuff()rescueException=>raisee,"specificerrortologinadb"doStuff代码抛出了几十个异常,我想捕获这些事件中的每一个以放入数据库中。有一个doStuff2(),它也可以抛出相同的指令,我想知道它们来自哪个函数。添加额外的字符串,似乎改变了异常本身,我失去了原始异常所具有的所有漂亮的格式和跟踪信息。关于如何重新引发原始异常,同时跟踪doStuff()中发

ruby - 将参数传递给 rspec 共享示例

我有一个返回结果集的过程,我想使用rspec测试该结果集的有效性。该过程将根据参数返回不同的结果,但有许多示例对所有参数都是通用的,因此我想创建一组通用示例,我可以针对所有这些示例运行。我知道首选的做法是使用let来构建结果。问题是每个过程需要一两分钟才能生成结果,而我大概有30个示例。使用基于不同参数的所有排列,我运行了大约500个示例。如果我必须为每个示例重建结果,测试将运行一天以上。所以我在before(:all)block中构建结果并将其分配给如下属性:RSpec.describe'TestDescription'doattr_reader:resultbefore(:all)